package com.lineage.data.npc.mob;

import com.lineage.data.cmd.CreateNewItem;
import com.lineage.data.executor.NpcExecutor;
import com.lineage.server.model.Instance.L1DoorInstance;
import com.lineage.server.model.Instance.L1NpcInstance;
import com.lineage.server.model.Instance.L1PcInstance;
import com.lineage.server.model.L1Character;
import com.lineage.server.model.L1Object;
import com.lineage.server.utils.CheckUtil;
import com.lineage.server.world.World;

import java.util.Iterator;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

public class ADLv80_Keeper1 extends NpcExecutor {
  private static final Log _log = LogFactory.getLog(ADLv80_Keeper1.class);
  
  public static NpcExecutor get() {
    return new ADLv80_Keeper1();
  }
  
  public int type() {
    return 8;
  }
  
  public L1PcInstance death(L1Character lastAttacker, L1NpcInstance npc) {
    try {
      L1PcInstance pc = CheckUtil.checkAtkPc(lastAttacker);
      if (pc != null && pc.getMapId() == 1017) {
          Iterator<L1Object> iterator = World.get().getVisibleObjects(1017).values().iterator();
          while (iterator.hasNext()) {
            L1Object obj = iterator.next();
            if (obj instanceof L1DoorInstance) {
              L1DoorInstance door = (L1DoorInstance)obj;
              if (door.get_showId() != pc.get_showId() || door.getDoorId() != 10037)
                continue; 
              door.open();
              door.deleteMe();
            } 
          } 
        } 
        return pc;
      } catch (Exception e) {
        _log.error(e.getLocalizedMessage(), e);
        return null;
      } 
    }
  }